// JavaScript Document

function startmarquee(lh, speed, delay, index) {
	/*
	 * 函数startmarquee的参数： lh：文字一次向上滚动的距离或高度； speed：滚动速度； delay：滚动停顿的时间间隔；
	 * index：可以使封装后的函数应用于页面当中不同的元素；
	 */
	var t;
	var p = false;
	var o = document.getElementById("marqueebox" + index);
	// 获取文档中的滚动区域对象，赋值给变量o；
	o.innerHTML += o.innerHTML; // 对象中的实际内容被复制了一份，包含了两个ul，当然li标签也由原来的3行，变为6行；复制的目的在于给文字不间断向上滚动提供过渡。
	o.onmouseover = function() {
		p = true
	}
	// 鼠标滑过，停止滚动；
	o.onmouseout = function() {
		p = false
	}
	// 鼠标离开，开始滚动；p是true还是false直接影响到下面start()函数的执行；
	o.scrollTop = 0;
	// 文字内容顶端与滚动区域顶端的距离，初始值为0；
	function start() {
		t = setInterval(scrolling, speed); // 每隔一段时间，setInterval便会执行一次scrolling函数；speed越大，滚动时间间隔越大，滚动速度越慢；
		if (!p) {
			o.scrollTop += 6;
		}
		// 滚动停止或开始，取决于p传来的布尔值；
	}
	function scrolling() {
		if (o.scrollTop % lh != 0) {
			// 如果不被整除，即一次上移的高度达不到lh，则内容会继续往上滚动；
			o.scrollTop += 6;
			if (o.scrollTop >= o.scrollHeight / 2)
				o.scrollTop = 0;
			// 对象o中的内容之前被复制了一次，所以它的滚动高度，其实是原来内容的两倍高度；当内容向上滚动到scrollHeight/2的高度时，全部3行文字已经显示了一遍，至此整块内容scrollTop归0；再等待下一轮的滚动，从而达到文字不间断向上滚动的效果；
		} else {
			clearInterval(t);
			// 否则清除t，暂停滚动
			setTimeout(start, delay);
			// 经过delay间隔后，启动start() 再连续滚动
		}
	}
	setTimeout(start, delay);
	// 第一次启动滚动；setTimeout会在一定的时间后执行函数start()，且只执行一次
}
// 传递参数
startmarquee(30, 30, 3000, 0);
// 带停顿效果
